package com.slofzx.nuoda.evaluation.project.service;

import com.slofzx.nuoda.evaluation.project.dto.ProjectInfoExcelDTO;
import com.slofzx.nuoda.evaluation.project.dto.ProjectYearDataDTO;
import com.slofzx.nuoda.evaluation.project.dto.ProjectYearDataExcelDTO;
import com.slofzx.nuoda.evaluation.project.vo.ProjectYearDataVO;
import com.slofzx.nuoda.common.enums.ServiceResult;

import java.util.List;
import java.util.Map;
import java.util.Set;

/**
 * 项目年度数据(ProjectYearData)表服务接口
 *
 * @author nuoda
 * @since 2023-10-20 15:57:43
 */
public interface ProjectYearDataService {

    /**
     * 通过ID查询单条数据
     *
     * @param id 主键
     * @return 实例对象
     */
    ProjectYearDataVO queryById(String id);

    /**
     * 查询多条数据
     *
     * @param dto 数据传递类实例对象
     * @return 对象列表
     */
    List<ProjectYearDataVO> queryList(ProjectYearDataDTO dto);

    /**
     * 新增数据
     *
     * @param dto 数据传递类实例对象
     * @return 操作结果
     */
    ServiceResult create(ProjectYearDataDTO dto);

    /**
     * 修改数据
     *
     * @param dto 数据传递类实例对象
     * @return 操作结果
     */
    ServiceResult update(ProjectYearDataDTO dto);

    /**
     * 通过主键删除数据
     *
     * @param id 主键
     * @return 操作结果
     */
    ServiceResult deleteById(String id);
    /**
     * 导入Excel数据
     * */
    ServiceResult importExcelData(String batchId, List<ProjectYearDataDTO> excelOriDataList);
    /**
     * 获取excel导出数据
     * */
    List<ProjectYearDataExcelDTO> getExcelData(String batchId);

    Map<String,List<Map<String,String>>> queryRatioByProjectIds(Set<String> projectIds);

    ServiceResult saveRatio(List<ProjectYearDataDTO> dto);
}
